•  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
r14
r1

(새 문서)
1[목차]
2== 개요 ==
3시스템 엔지니어링 1차 과제 중 Linux Script 작성 실습과 관련된 문서이다.
4
5== 제 0과제 ==
6scp 명령어 이용해 과제 수행에 필요한 파일들을 받아오는 과제이다.
7scp 사용법은 아래와 같다.
r9
8[br]
r1

(새 문서)
9># scp 원격ID@원격서버IP:파일위치 받는위치
10>Ex) scp root@172.16.48.201:"/home/test/{test1[20250109].txt,test2.sh,test[3].log,testfile,}" /home/test_user
11위 예시 명령어 확인 시 파일을 한번에 받아오기 위해 중괄호를 추가했고 파일명 중 대괄호가 포함되어 있어 쌍따옴표를 넣어줬다.
12
r12
13----
14사용 명령어 및 함수 : scp
15
r1

(새 문서)
16== 제 1과제 ==
172개의 파일 리스트를 비교해 같은 내용이 있는 라인을 출력하는 과제이다.
r14
18diff 명령어를 사용해 중복된 라인을 출력 후 파일에 넣도록 스크립트를 작성했다.
r9
19[br]
r1

(새 문서)
20> diff "$FILE1" "$FILE2" | grep '^<' | sed 's/^< //' >> "$OUTPUT_FILE"
r9
21명령어 확인 시 스크립트 파일에서 특수기호 "^<" 사용을 위해 따옴표를 넣어줬다.
r1

(새 문서)
22
r10
23----
r11
24사용 명령어 및 함수 : grep, diff, sed
25
r14
26===# 제 1과제 출력 결과 #===
27{{{H0102023FOD0308030.mpg
28H0602024FOD0823006.mpg
29H0602024FOD0823007.mpg
30H0602024FOD0823008.mpg
31H0602024FOD0823009.mpg
32H0602024FOD0823010.mpg
33H0602024FOD0823011.mpg
34H0602024FOD0823012.mpg
35H0602024FOD0823013.mpg
36H0602024FOD0823014.mpg
37H0602024FOD0823015.mpg
38H0602024FOD0823016.mpg
39H0602024FOD0823017.mpg
40HCBCASD201229.mpg
41HCBFOHD210120.mpg
42HCXNFHD200319.mpg
43HCYLVHD200529.mpg
44M0026360.mpg
45M0026361.mpg
46M0026362.mpg
47M0026363.mpg
48M0026364.mpg
49M0026365.mpg
50M5245079.mpg
51M5245086.mpg
52M5245087.mpg
53M5245089.mpg
54M5245090.mpg
55M5245094.mpg}}}
56
r1

(새 문서)
57== 제 2과제 ==
58대용량 파일을 비교해 공통으로 존재 하는것과 하지 않는 라인을 각각 다른 파일에 저장하는 과제이다.
r3
59diff 명령어를 사용해 각각 다른 파일에 저장하도록 스크립트를 작성했다.
r9
60[br]
r1

(새 문서)
61> diff "$FILE1" "$FILE2" | grep '^>' | sed 's/^> //' | awk '{print $1}' | grep -v 'filename' >> "$EXIST_FILE"
62> diff "$FILE1" "$FILE2" | grep '^<' | sed 's/^< //' | awk -F '[,\t ]+' '{print $1}' >> "$NOT_EXIST_FILE"
63위 명령어 확인 시 제 1과제 명령어와[*1 diff "$FILE1" "$FILE2" | grep '^<' | sed 's/^< //' >> "$OUTPUT_FILE"] 비슷하지만,
64awk를 추가해 필요한 정보만 걸러서 저장하도록 했다.
65중복되는 컨텐츠 리스트와 중복되지 않는 리스트를 각각 저장하도록했다.
r5
66
r11
67----
68사용 명령어 및 함수 : grep, sed, awk
69
r14
70===# 제 2과제 출력 결과 #===
71{{{## 공통으로 존재하는 리스트 출력 결과 ##
72M5292473.mpg
73M5268158.mpg
74M5293857.mpg
75M5253970.mpg
76M5270540.mpg
77M5301053.mpg
78M5295048.mpg
79M5218576.mpg
80M5246713.mpg...}}}
81
82{{{## 존재하지 않는 리스트 출력 결과 ##
83historyheader:1731900096
84.a.swp
851sec_110324.mpg
861sec_111227.mpg
87H0102022FOD0126015.mpg
88H0102022FOD0801017.mpg
89H0102022FOD0818015.mpg
90H0102022FOD1109013.mpg
91H0102022FOD1206008.mpg
92H0102022FOD1212004.mpg
93H0102022FOD1212007.mpg
94H0102022FOD1228018.mpg
95H0102023FOD0102017.mpg
96H0102023FOD0118010.mpg
97H0102023FOD0203014.mpg
98H0102023FOD0206017.mpg
99H0102023FOD0214006.mpg
100H0102023FOD0216014.mpg
101H0102023FOD0223005.mpg
102H0102023FOD0302030.mpg
103H0102023FOD0308015.mpg
104H0102023FOD0308030.mpg
105H0102023FOD0309006.mpg}}}
106
r1

(새 문서)
107== 제 3과제 ==
108파일에 기록된 시간을 보기 편하게 변환해 별도 파일에 저장하는 과제이다.
r9
109[br]
r3
110> cat "$FILE1" | grep -v history | awk -F ',' '{print $1 "," strftime("%Y-%m-%d %H:%M:%S", $2)}' >> $EXIST_FILE
r5
111strftime 함수를 이용해 파일 내 쉼표 2번째의 있는 텍스트(날짜)를 보기편하게(yyyy-mm-dd hh-mm-ss) 변환한다.
r1

(새 문서)
112
113|| AS-IS || TO-BE ||
r6
114|| 1721693207 || 2024-07-09 09:16:44 ||
r1

(새 문서)
115
r11
116----
117사용 명령어 및 함수 : grep, sed, strftime
118
r14
119===# 제 3과제 출력 결과 #===
120{{{1sec_110324.mpg,2016-12-08 16:44:16
1211sec_111227.mpg,2020-06-05 14:38:59
122H0102022FOD0126015.mpg,2023-09-21 19:39:20
123H0102022FOD0801017.mpg,2023-10-20 13:40:52
124H0102022FOD0818015.mpg,2023-12-27 17:45:50
125H0102022FOD1109013.mpg,2023-09-19 11:21:30
126H0102022FOD1206008.mpg,2023-11-14 17:07:44
127H0102022FOD1212004.mpg,2023-09-25 17:47:41
128H0102022FOD1212007.mpg,2023-10-24 13:06:43
129H0102022FOD1228018.mpg,2023-09-19 16:16:59
130H0102023FOD0102017.mpg,2023-09-20 09:59:54
131H0102023FOD0118010.mpg,2023-08-07 16:36:09
132H0102023FOD0203014.mpg,2023-08-29 16:25:55}}}
133
r1

(새 문서)
134== 제 4과제 ==
r6
135파일내 bitrate 값의 따라 각각 다른 파일의 저장하는 과제이다.
r11
136if문을 통해 6Mbps인 경우 4~6M
137 hd_cnt++; hd_sum += bibps인 경우 그 외 데이터를 각각 저장 할 수 있도록 작성했다.
r6
138
r9
139{{{if (bitrate >= 6000000) {
r11
140 print out >> "HD.txt";trate;
r9
141} }}}bitrate 값 마다 분리 해주는 구문이다.
r1

(새 문서)
142다른 값들도 구문과 같이 각각 분리해 준다.
143
144{{{if (hd_cnt > 0) {
145 res = sprintf("total : %d, bitrate avg : %.0f", hd_cnt, hd_sum / hd_cnt);
146 print res >> "HD.txt";
r9
147} }}}파일 마지막 줄에 나눈 파일 마다의 총 파일의 개수와 평균 bitrate를 계산한 값을 출력하도록했다.
r7
148다른 값들도 구문과 같이 총파일 개수와 평균 bitrate를 출력한다.
149
r11
150----
151사용 명령어 및 함수 : print , sprintf
r4
152
r14
153===# 제 4과제 출력 결과 #===
154{{{## HD.txt ##
1551sec_110324.mpg,2016-12-08 16:44:16
1561sec_111227.mpg,2020-06-05 14:38:59
157H0102022FOD0126015.mpg,2023-09-21 19:39:20
158H0102022FOD0801017.mpg,2023-10-20 13:40:52
159H0102022FOD0818015.mpg,2023-12-27 17:45:50
160H0102022FOD1109013.mpg,2023-09-19 11:21:30
161H0102022FOD1206008.mpg,2023-11-14 17:07:44
162H0102022FOD1212004.mpg,2023-09-25 17:47:41
163H0102022FOD1212007.mpg,2023-10-24 13:06:43
164H0102022FOD1228018.mpg,2023-09-19 16:16:59}}}
165
166{{{## SD.txt ##
167HCAAKHD200921.mpg,1600649855,5905200
168HCAARHD200921.mpg,1600667966,5905200
169HCAAWHD200923.mpg,1600824404,5905200
170HCAAXHD200923.mpg,1600824580,5905200
171HCABMHD200925.mpg,1601012433,5905200
172HCADIHD200928.mpg,1601274244,5905200
173HCAEDHD200929.mpg,1601341620,5905200
174HCAEEHD200929.mpg,1601342072,5905200}}}
175
176{{{## check.txt ##
177.a.swp,1460369255,0
1781sec_110324.mpg,1481183056,3684427
179HCAAKSD200921.mpg,1600649698,3757500
180HCAARSD200921.mpg,1600667884,3757500
181HCAAWSD200923.mpg,1600824217,3757500
182HCAAXSD200923.mpg,1600824091,3757500
183HCABMSD200925.mpg,1601012525,3757500
184HCADISD200928.mpg,1601274635,3757500
185HCAEDSD200929.mpg,1601341711,3757500
186HCAEESD200929.mpg,1601341883,3757500}}}
187
r4
188== 제 5과제 ==
r1

(새 문서)
189입력한 용량 값 만큼의 컨텐츠 크기인 파일만 출력하는 과제이다.
r9
190[br]
r7
191> grep "^H" hitcount.txt
192H로 시작하는 컨텐츠 파일만 조회 하기 위해 grep에 ^를 추가해 준다.
r9
193[br]
r4
194> current_gb = $4/1024/1024/1024;
r1

(새 문서)
195리스트 파일에 있는 컨텐츠 별 용량을 구해 GB로 변환 해준다.
196
r9
197{{{if (current_gb < limit) {
r11
198 printf "%s, %s, %s, %.2f GB, %s\n", $1, v$2, $3, current_gb, $5
r9
199} }}}if문을 통해 입력한 GB 값과 파일리스트의 GB변환값을 비교해 미만인 파일들을 출력해준다.
r1

(새 문서)
200
r11
201----
r13
202사용 명령어 및 함수 : read, sprintf, grep, awk
r11
203
r14
204===# 제 5과제 출력 결과 #===
205
206{{{[root@testServer work5]# ./event_show.sh
207Input SIZE(GB) : 1
208H0102022FOD0126015.mpg, 1695292760, 6017250, 0.83 GB, 192.168.41.102 192.168.41.110
209H0102022FOD0801017.mpg, 1697776852, 6017250, 0.83 GB, 192.168.41.181 192.168.41.182
210H0102022FOD0818015.mpg, 1703666750, 6017250, 0.83 GB, 192.168.41.181 192.168.41.182
211H0102022FOD1109013.mpg, 1695090090, 6017250, 0.04 GB, 192.168.41.102 192.168.41.183
212H0102022FOD1206008.mpg, 1699949264, 6017250, 0.83 GB, 192.168.41.118 192.168.41.183
213H0102022FOD1212004.mpg, 1695631661, 6017250, 0.83 GB, 192.168.41.114 192.168.41.183...
214}}}
215
216{{{[root@testServer work5]# ./event_show.sh
217Input SIZE(GB) : 0.5
218H0102022FOD1109013.mpg, 1695090090, 6017250, 0.04 GB, 192.168.41.102 192.168.41.183
219H0102023FOD0321010.mpg, 1690260213, 6017250, 0.42 GB, 192.168.41.181 192.168.41.182
220H0102023FOD0403005.mpg, 1708304121, 6017250, 0.42 GB, 192.168.41.117 192.168.41.118
221H0102023FOD0531006.mpg, 1714728859, 6017250, 0.42 GB, 192.168.41.181 192.168.41.182
222H0102023FOD0614002.mpg, 1714729449, 6017250, 0.42 GB, 192.168.41.181 192.168.41.182
223H0102024FOD0523010.mpg, 1716451462, 6017250, 0.42 GB, 192.168.41.118 192.168.41.182...}}}
224
r8
225== 제 6과제 ==
r1

(새 문서)
226파일이 복사된 서버의 IP 리스트의 개수와 파일이 복사된 개수를 비교해 두 값이 다른걸 출력하는 과제이다.
r9
227[br]
r2
228> split($5, ips, " ");
229> ip_cnt = length(ips);
r4
230> copy_cnt = $6;
231split 함수를 이용해 IP 리스트 개수를 출력,
232복사된 개수는 이미 Count되어 있어 값을 가져 올 수 있다.
r9
233[br]
234{{{if (ip_cnt != copy_cnt) {
r2
235 printf "불일치: %s (실제:%d, 기록:%d)\n", $1, ip_cnt, copy_cnt
r9
236} }}}if문을 통해 불일치 값을 출력해 남겨준다.
r2
237
r11
238----
239사용 명령어 및 함수 : split, if, printf
240
r14
241===# 제 6과제 출력 결과 #===
242
243{{{불일치: H0602024FOD0611015.mpg (실제:2, 기록:3)
244불일치: M4330604.mpg (실제:2, 기록:3)
245불일치: M4622038.mpg (실제:2, 기록:3)
246불일치: M4726665.mpg (실제:2, 기록:3)
247불일치: M4726666.mpg (실제:2, 기록:3)
248불일치: M5224716.mpg (실제:3, 기록:4)
249불일치: M5263260.mpg (실제:3, 기록:4)
250불일치: M5293015.mpg (실제:3, 기록:4)
251불일치: M5293063.mpg (실제:3, 기록:4)
252불일치: M5293072.mpg (실제:3, 기록:4)
253불일치: M5293078.mpg (실제:3, 기록:4)
254불일치: M5293093.mpg (실제:3, 기록:4)
255불일치: M5293147.mpg (실제:3, 기록:4)}}}
256
r2
257== 제 7과제 ==
258EventLog에서 SeesionID로 조회해 관련로그를 출력 및 관련 컨텐츠 파일을 다른 파일에서도 조회해 출력하는 과제이다.
r9
259[br]
r1

(새 문서)
260> grep "$sid" EventLog\[20241118\].log
261SessionID를 입력받아 관련 로그를 조회한다.
r9
262[br]
r4
263> grep "$sid" EventLog\[20241118\].log | grep ".mpg" | sed -E 's/.*[[,/ ]([^,/[ ]+\.mpg).*/\1/' | sort -u
264mpg 파일을 다른 파일에서도 조회 하기 위해 mpg 목록들을 출력한다.
265
r11
266----
r13
267사용 명령어 및 함수 : read, grep, if, sed, sort, while
r11
268
r14
269===# 제 7과제 출력 결과 #===
270{{{[root@testServer work7]# ./event_show.sh
271조회할 sessionID : e0072144-8c91-4e15-bfb6-2c2b746008bc
2720x8ffff,1,1731855612,90,Received Request OnDemandSession (SessionID [e0072144-8c91-4e15-bfb6-2c2b746008bc/99206], StreamID [0786e652-e341-4167-af1f-b8f863a6661b], dest IP [172.16.2.143], dest port [263], peerip [192.168.43.19], file [/data2/M4991043.mpg])
2730x2ffff,1,1731855612,90,RTSP::Reserved Session(e0072144-8c91-4e15-bfb6-2c2b746008bc) Stream(0786e652-e341-4167-af1f-b8f863a6661b) : file(M4991043.mpg), request file(M4991043.mpg)
2740x40ffff,1,1731855612,event_type[AdverTisement], session(e0072144-8c91-4e15-bfb6-2c2b746008bc) : Get Advertise. - Type(ADM), Advertise(1sec_111227.mpg[-1*1*Tracking=00000000-0000-0000-0000-000000000000],HCDSUHD241018.mpg[-1*1*Tracking=2c8ae4c09ca240f780ec7ec2a49fa226],HCDTZHD241113.mpg[-1*1*Tracking=0f4c8e29bde6404cb6b816e9a956293e])
2750x40ffff,4,1731855612,event_type[AdverTisement], session(e0072144-8c91-4e15-bfb6-2c2b746008bc) : Disabled ADV schedule parsing for resume.
2760x10001,1,1731855612,90,99206,10.183.5.100,M4991043.mpg,2,1731855612,1731855612,SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b]
2770x4ffff,1,1731855612,90,99206,10.183.5.100,M4991043.mpg,Report Connection Established, SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b]
2780x4ffff,1,1731855612,90,99206,10.183.5.100,M4991043.mpg,SET_PARAMETER request for smart_card_id -> 17605388 SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b]
2790x4ffff,1,1731855612,90,99206,10.183.5.100,M4991043.mpg,SET_PARAMETER request for pincode -> UMP, UMP_1.0.0QR2 SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b]
2800x4ffff,1,1731855612,90,99206,10.183.5.100,M4991043.mpg,SET_PARAMETER request for menuid -> 6807005 SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b]
2810x4ffff,1,1731855612,90,99206,10.183.5.100,M4991043.mpg,Advertise File(/data1/1sec_111227.mpg) Start, SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc]. StreamID[0786e652-e341-4167-af1f-b8f863a6661b]
2820x10100,1,1731855612,90,99206,10.183.5.100,M4991043.mpg,2,1731855612,1731855612,SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b] seek offset : 1692
2830x10200,1,1731855614,90,99206,10.183.5.100,M4991043.mpg,2,1731855612,1731855614,event_type[AdverTisement], SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b], bandwidth[6073800], clientid[17605388], userid[], bitrate[6073800], systemtype[131072], videotype[1024], audiotype[4], filesize[1898236], filepath[/data1], filename[1sec_111227.mpg], filepath_attr[0], offset[1898236], result_type[1], params[menuid: 6807005], scheduletime[-1], mainfile[M4991043.mpg], adv_info[Tracking=00000000-0000-0000-0000-000000000000], vod_request_meta_info[], startoffset[1692], resetup[0], vod_request_id[cc57bb62-ad8f-4057-bba0-146ba302ea29], vod_ip[192.168.41.151]
2840x4ffff,1,1731855614,90,99206,10.183.5.100,M4991043.mpg,Advertise File(/data1/HCDSUHD241018.mpg) Start SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b]
2850x10200,1,1731855631,90,99206,10.183.5.100,M4991043.mpg,2,1731855614,1731855631,event_type[AdverTisement], SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b], bandwidth[5905200], clientid[17605388], userid[], bitrate[5905200], systemtype[131072], videotype[1024], audiotype[4], filesize[12154952], filepath[/data1], filename[HCDSUHD241018.mpg], filepath_attr[0], offset[12154952], result_type[1], params[menuid: 6807005], scheduletime[-1], mainfile[M4991043.mpg], adv_info[Tracking=2c8ae4c09ca240f780ec7ec2a49fa226], vod_request_meta_info[], startoffset[1692], resetup[0], vod_request_id[cc57bb62-ad8f-4057-bba0-146ba302ea29], vod_ip[192.168.41.151]
2860x4ffff,1,1731855631,90,99206,10.183.5.100,M4991043.mpg,Advertise File(/data1/HCDTZHD241113.mpg) Start SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b]
2870x10200,1,1731855647,90,99206,10.183.5.100,M4991043.mpg,2,1731855631,1731855647,event_type[AdverTisement], SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b], bandwidth[5905200], clientid[17605388], userid[], bitrate[5905200], systemtype[131072], videotype[1024], audiotype[4], filesize[12154952], filepath[/data1], filename[HCDTZHD241113.mpg], filepath_attr[0], offset[12154952], result_type[1], params[menuid: 6807005], scheduletime[-1], mainfile[M4991043.mpg], adv_info[Tracking=0f4c8e29bde6404cb6b816e9a956293e], vod_request_meta_info[], startoffset[1692], resetup[0], vod_request_id[cc57bb62-ad8f-4057-bba0-146ba302ea29], vod_ip[192.168.41.151]
2880x10004,1,1731855674,90,99206,10.183.5.100,M4991043.mpg,2,1731855612,1731855674,SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b], Scale 2
2890x10004,1,1731855676,90,99206,10.183.5.100,M4991043.mpg,2,1731855612,1731855676,SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b], Scale 4
2900x10004,1,1731855677,90,99206,10.183.5.100,M4991043.mpg,2,1731855612,1731855677,SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b], Scale 8
2910x10080,1,1731855718,90,99206,10.183.5.100,M4991043.mpg,2,1731855612,1731855718,SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b]
2920x10002,1,1731855719,90,99206,10.183.5.100,M4991043.mpg,2,1731855612,1731855719,SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b]
2930x10200,1,1731855719,90,99206,10.183.5.100,M4991043.mpg,2,1731855612,1731855719,SessionID[e0072144-8c91-4e15-bfb6-2c2b746008bc], StreamID[0786e652-e341-4167-af1f-b8f863a6661b], bandwidth[6073800], clientid[17605388], userid[], bitrate[6073800], systemtype[131072], videotype[1024], audiotype[4], filesize[3219443036], filepath[/data2], filename[M4991043.mpg], filepath_attr[0], offset[240276220], result_type[1], params[menuid: 6807005], insert_sent[26208140], bytes_sent[79849992], vod_request_meta_info[], startoffset[1692], resetup[0], vod_request_id[cc57bb62-ad8f-4057-bba0-146ba302ea29], vod_ip[192.168.41.151]
294
295===== file select =====
2961sec_111227.mpg
297file(M4991043.mpg
298HCDSUHD241018.mpg
299HCDTZHD241113.mpg
300M4991043.mpg
301
302===== select hitcount =====
3031sec_111227.mpg,1591335539,6073800,1898236,192.168.41.101 192.168.41.102 192.168.41.103 192.168.41.108 192.168.41.109 192.168.41.110 192.168.41.111 192.168.41.112 192.168.41.113 192.168.41.114 192.168.41.116 192.168.41.117 192.168.41.118 192.168.41.181 192.168.41.182 192.168.41.183,16,0,0,0=0 0
304HCDSUHD241018.mpg,1729235522,5905200,12154952,192.168.41.101 192.168.41.102 192.168.41.103 192.168.41.108 192.168.41.109 192.168.41.110 192.168.41.111 192.168.41.112 192.168.41.113 192.168.41.114 192.168.41.116 192.168.41.117 192.168.41.118 192.168.41.181 192.168.41.182 192.168.41.183,16,0,0,0=0 0
305HCDTZHD241113.mpg,1731485917,5905200,12154952,192.168.41.101 192.168.41.102 192.168.41.103 192.168.41.108 192.168.41.109 192.168.41.110 192.168.41.111 192.168.41.112 192.168.41.113 192.168.41.114 192.168.41.116 192.168.41.117 192.168.41.118 192.168.41.181 192.168.41.182 192.168.41.183,16,0,0,0=0 0}}}
306
307
r1

(새 문서)
308== 제 8과제 ==
309EventLog에서 SeesionID로 조회해 관련로그를 출력 및 관련 컨텐츠 파일을 다른 파일에서도 조회해 출력하는 과제이다.
r9
310[br]
r1

(새 문서)
311> grep "$sid" EventLog\[20241118\].log
312SessionID를 입력받아 관련 로그를 조회한다.
r9
313[br]
r1

(새 문서)
314> grep "$sid" EventLog\[20241118\].log | grep ".mpg" | sed -E 's/.*[[,/ ]([^,/[ ]+\.mpg).*/\1/' | sort -u
315mpg 파일을 다른 파일에서도 조회 하기 위해 mpg 목록들을 출력한다.
r9
316[br]
r2
317> start_ts=$(date -d "$LOG_DATE $start_input" +%s)
318> Ex) inout = 10
319> 변환 후 --> 10:30:00
320입력받은 시간을 변환을 하기 위한 구문이다.
r9
321[br]
r2
322> awk -F',' -v s="$start_ts" -v e="$end_ts" '$3 >= s && $3 <= e' "$FILE"
323입력한 시작 시간보다 큰 값과 입력한 종료 시간보다 작거나 같은 값을 출력한다.
324
r11
325----
326사용 명령어 및 함수 : read, awk, sed
r2
327
r14
328===# 제 8과제 출력 결과 #===
329
330{{{[root@testServer work8]# ./select_hour.sh
331Start Hour : 11:00
332End Hour : 11:01
3330x10004,1,1731895205,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895205,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 2
3340x10004,1,1731895206,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895206,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 4
3350x10004,1,1731895206,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895206,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 8
3360x10004,1,1731895207,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895207,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 16
3370x10040,1,1731895217,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895217,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02]
3380x10080,1,1731895221,90,99462,10.158.154.220,M4994600.mpg,2,1731893212,1731895221,SessionID[272b2c9d-2288-4cf4-bb07-2ee31800341c], StreamID[1b803e81-52a9-4a1e-bd9a-0580452904c0]
3390x10002,1,1731895221,90,99462,10.158.154.220,M4994600.mpg,2,1731893212,1731895221,SessionID[272b2c9d-2288-4cf4-bb07-2ee31800341c], StreamID[1b803e81-52a9-4a1e-bd9a-0580452904c0]
3400x10200,1,1731895221,90,99462,10.158.154.220,M4994600.mpg,2,1731893212,1731895221,SessionID[272b2c9d-2288-4cf4-bb07-2ee31800341c], StreamID[1b803e81-52a9-4a1e-bd9a-0580452904c0], bandwidth[6073800], clientid[], userid[], bitrate[6073800], systemtype[131072], videotype[1024], audiotype[4], filesize[3836009716], filepath[/data1], filename[M4994600.mpg], filepath_attr[0], offset[3461847792], result_type[1], params[], insert_sent[25125448], bytes_sent[1524970460], vod_request_meta_info[], startoffset[1692], resetup[0], vod_request_id[98392774-61ad-4435-8cb2-03641516314c], vod_ip[192.168.41.151]
3410x8ffff,1,1731895221,90,SendRequestStreamStateNotification count : 1
3420x10004,1,1731895224,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895224,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 2
3430x10004,1,1731895224,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895224,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 4
3440x10004,1,1731895225,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895225,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 8
3450x10004,1,1731895225,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895225,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 16
3460x10040,1,1731895227,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895227,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02]
3470x8ffff,1,1731895236,90,Received Request OnDemandSession (SessionID [093d0146-5993-43a8-bbb7-5a9ca03b9595/88470], StreamID [85629a14-9705-4dd3-9e92-76ae19979d57], dest IP [172.16.132.139], dest port [270], peerip [192.168.43.19], file [/data1/M4337604.mpg])
3480x2ffff,1,1731895236,90,RTSP::Reserved Session(093d0146-5993-43a8-bbb7-5a9ca03b9595) Stream(85629a14-9705-4dd3-9e92-76ae19979d57) : file(M4337604.mpg), request file(M4337604.mpg)
3490x40ffff,1,1731895236,event_type[AdverTisement], session(093d0146-5993-43a8-bbb7-5a9ca03b9595) : Get Advertise. - Type(ADM), Advertise(1sec_111227.mpg[-1*1*Tracking=00000000-0000-0000-0000-000000000000],HCDTWHD241107.mpg[-1*1*Tracking=0752fe98edea4202a62038535409fa75])
3500x40ffff,4,1731895236,event_type[AdverTisement], session(093d0146-5993-43a8-bbb7-5a9ca03b9595) : Disabled ADV schedule parsing for resume.
3510x10001,1,1731895236,90,88470,10.155.150.52,M4337604.mpg,2,1731895236,1731895236,SessionID[093d0146-5993-43a8-bbb7-5a9ca03b9595], StreamID[85629a14-9705-4dd3-9e92-76ae19979d57]
3520x8ffff,1,1731895236,90,SendRequestStreamStateNotification count : 1
3530x4ffff,1,1731895236,90,88470,10.155.150.52,M4337604.mpg,Report Connection Established, SessionID[093d0146-5993-43a8-bbb7-5a9ca03b9595], StreamID[85629a14-9705-4dd3-9e92-76ae19979d57]
3540x4ffff,1,1731895236,90,88470,10.155.150.52,M4337604.mpg,Advertise File(/data1/1sec_111227.mpg) Start, SessionID[093d0146-5993-43a8-bbb7-5a9ca03b9595]. StreamID[85629a14-9705-4dd3-9e92-76ae19979d57]
3550x10100,1,1731895236,90,88470,10.155.150.52,M4337604.mpg,2,1731895236,1731895236,SessionID[093d0146-5993-43a8-bbb7-5a9ca03b9595], StreamID[85629a14-9705-4dd3-9e92-76ae19979d57] seek offset : 4136
3560x8ffff,1,1731895236,90,Received Request OnDemandSession (SessionID [b70923f0-6103-4c56-8d84-4e365348b86f/105693], StreamID [05f78147-affe-44bb-912b-52dcd3b7e92a], dest IP [172.16.98.130], dest port [264], peerip [192.168.43.19], file [/data1/M5260132.mpg])
3570x2ffff,1,1731895236,90,RTSP::Reserved Session(b70923f0-6103-4c56-8d84-4e365348b86f) Stream(05f78147-affe-44bb-912b-52dcd3b7e92a) : file(M5260132.mpg), request file(M5260132.mpg)
3580x40ffff,1,1731895236,event_type[AdverTisement], session(b70923f0-6103-4c56-8d84-4e365348b86f) : Get Advertise. - Type(ADM), Advertise(1sec_111227.mpg[-1*1*Tracking=00000000-0000-0000-0000-000000000000],HCDTXHD241108.mpg[-1*1*Tracking=c746af766af2435d9f169357b75befcb],HCDSUHD241018.mpg[-1*1*Tracking=5d90d1dbd138454e9784a68fe9411456],HCDUAHD241113.mpg[-1*1*Tracking=71c49e0325354c3c99d6bdd85833c5f4],HCDTZHD241113.mpg[-1*1*Tracking=713d45b85e4249c79a32eb28e1da454b])
3590x40ffff,4,1731895236,event_type[AdverTisement], session(b70923f0-6103-4c56-8d84-4e365348b86f) : Disabled ADV schedule parsing for resume.
3600x10001,1,1731895236,90,105693,10.148.69.219,M5260132.mpg,2,1731895236,1731895236,SessionID[b70923f0-6103-4c56-8d84-4e365348b86f], StreamID[05f78147-affe-44bb-912b-52dcd3b7e92a]
3610x4ffff,1,1731895237,90,105693,10.148.69.219,M5260132.mpg,Report Connection Established, SessionID[b70923f0-6103-4c56-8d84-4e365348b86f], StreamID[05f78147-affe-44bb-912b-52dcd3b7e92a]
3620x4ffff,1,1731895237,90,105693,10.148.69.219,M5260132.mpg,SET_PARAMETER request for smart_card_id -> 17709151 SessionID[b70923f0-6103-4c56-8d84-4e365348b86f], StreamID[05f78147-affe-44bb-912b-52dcd3b7e92a]
3630x4ffff,1,1731895237,90,105693,10.148.69.219,M5260132.mpg,SET_PARAMETER request for pincode -> UMP, UMP_1.0.0QR2 SessionID[b70923f0-6103-4c56-8d84-4e365348b86f], StreamID[05f78147-affe-44bb-912b-52dcd3b7e92a]
3640x4ffff,1,1731895237,90,105693,10.148.69.219,M5260132.mpg,SET_PARAMETER request for menuid -> 9955176 SessionID[b70923f0-6103-4c56-8d84-4e365348b86f], StreamID[05f78147-affe-44bb-912b-52dcd3b7e92a]
3650x4ffff,1,1731895237,90,105693,10.148.69.219,M5260132.mpg,Advertise File(/data1/1sec_111227.mpg) Start, SessionID[b70923f0-6103-4c56-8d84-4e365348b86f]. StreamID[05f78147-affe-44bb-912b-52dcd3b7e92a]
3660x10100,1,1731895237,90,105693,10.148.69.219,M5260132.mpg,2,1731895236,1731895237,SessionID[b70923f0-6103-4c56-8d84-4e365348b86f], StreamID[05f78147-affe-44bb-912b-52dcd3b7e92a] seek offset : 1692
3670x10200,1,1731895237,90,88470,10.155.150.52,M4337604.mpg,2,1731895236,1731895237,event_type[AdverTisement], SessionID[093d0146-5993-43a8-bbb7-5a9ca03b9595], StreamID[85629a14-9705-4dd3-9e92-76ae19979d57], bandwidth[6073800], clientid[], userid[], bitrate[6073800], systemtype[131072], videotype[1024], audiotype[4], filesize[1898236], filepath[/data1], filename[1sec_111227.mpg], filepath_attr[0], offset[1898236], result_type[1], params[], scheduletime[-1], mainfile[M4337604.mpg], adv_info[Tracking=00000000-0000-0000-0000-000000000000], vod_request_meta_info[], startoffset[4136], resetup[0], vod_request_id[ddc5b69e-fa0c-4f63-8ba7-67f6daa5424a], vod_ip[192.168.41.151]
3680x4ffff,1,1731895237,90,88470,10.155.150.52,M4337604.mpg,Advertise File(/data1/HCDTWHD241107.mpg) Start SessionID[093d0146-5993-43a8-bbb7-5a9ca03b9595], StreamID[85629a14-9705-4dd3-9e92-76ae19979d57]
3690x10200,1,1731895238,90,105693,10.148.69.219,M5260132.mpg,2,1731895237,1731895238,event_type[AdverTisement], SessionID[b70923f0-6103-4c56-8d84-4e365348b86f], StreamID[05f78147-affe-44bb-912b-52dcd3b7e92a], bandwidth[6073800], clientid[17709151], userid[], bitrate[6073800], systemtype[131072], videotype[1024], audiotype[4], filesize[1898236], filepath[/data1], filename[1sec_111227.mpg], filepath_attr[0], offset[1898236], result_type[1], params[menuid: 9955176], scheduletime[-1], mainfile[M5260132.mpg], adv_info[Tracking=00000000-0000-0000-0000-000000000000], vod_request_meta_info[], startoffset[1692], resetup[0], vod_request_id[2e7f5918-a7ed-4b7b-9e2c-0815239c68ce], vod_ip[192.168.41.151]
3700x4ffff,1,1731895238,90,105693,10.148.69.219,M5260132.mpg,Advertise File(/data1/HCDTXHD241108.mpg) Start SessionID[b70923f0-6103-4c56-8d84-4e365348b86f], StreamID[05f78147-affe-44bb-912b-52dcd3b7e92a]
3710x8ffff,1,1731895241,90,SendRequestStreamStateNotification count : 1
3720x10004,1,1731895259,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895259,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 2
3730x10004,1,1731895259,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895259,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 4
3740x10004,1,1731895260,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895260,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 8
3750x10004,1,1731895260,90,87860,10.146.69.251,M4805498.mpg,2,1731894915,1731895260,SessionID[5e567417-b10e-4cb3-a80e-30105ad8a8c7], StreamID[fa70b4e0-a3c3-4649-87b7-464d75d27b02], Scale 16}}}
376
377